package com.example.forum.dao;

import com.example.forum.model.Article;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

@Mapper
public interface ArticleMapper {
    int insert(Article row);

    int insertSelective(Article row);

    Article selectByPrimaryKey(Long id);

    int updateByPrimaryKeySelective(Article row);

    int updateByPrimaryKeyWithBLOBs(Article row);

    int updateByPrimaryKey(Article row);

    /**
     * 查询所有帖子列表
     * @return
     */
    List<Article> selectAll();

    /**
     * 查询所有未被删除的板块下的列表
     * @param boardId 板块id
     * @return 板块下的所有列表
     */
    List<Article> selectAllByBoardId(@Param("boardId") Long boardId);


    /**
     * 根据帖子id查询详情
     * @param id  帖子id
     * @return  帖子详情
     */
    Article selectDetailById(@Param("id") Long id);


    /**
     * 根据用户ID查询帖子列表
     * @param userId 用户id
     * @return 帖子列表
     */
    List<Article> selectByUserId(@Param("userId") Long userId);


    /**
     * 搜索全部
     * @param artName  关键字
     * @return
     */
    List<Article> selectSearch(String artName);

    /**
     * 搜索指定板块
     * @param artName  关键字
     * @param boardId   板块id
     * @return
     */
    List<Article> selectBoarSearch(String artName,Long boardId);
}